# Building a Pipelined Processor RISC V

Part 1

**RV32IM Instructions** 

And

Pipeline Datapath

Damsy De Silva (E/16/069)

Shirly Ekanayake (E/16/094)

Buddhi Perera (E/16/276)

## Contents

| Instruction Encoding Formats                | 2  |
|---------------------------------------------|----|
| Instructions in RV32IM                      | 3  |
| 2.1. Integer Computational Instructions     | 3  |
| 2.1.1. Register - Immediate Instructions    | 3  |
| 2.1.2. Register - Register Instructions     | 5  |
| 2.2. Control Transfer Instructions          | 6  |
| 2.3. Load and Store Instructions            | 8  |
| 2.4. Multiplication / Division Instructions | 9  |
| 2.5. Memory Ordering Instruction            | 10 |
| 2.6. Environment Call and Breakpoints       | 10 |
| Opcodes                                     | 11 |
| Pipeline Datapath                           | 13 |
| Hardware Units                              | 14 |
| Control Signals                             | 14 |

### 1.Instruction Encoding Formats

Instructions in RISC-V ISA can be divided into 4 main categories depending on their formats.

- 1. R-Type
- 2. I-Type
- 3. S-Type
- 4. U-Type

S-Type and U-Type instructions can be further categorized according to the way the immediate value is handled. Figure 1 shows the instruction formats in RISC-V ISA.

| 31 30 25                  | 24 21    | 20     | 19  | $15 \ 14$ | 12  | 11 8        | 7       | 6 0    |        |
|---------------------------|----------|--------|-----|-----------|-----|-------------|---------|--------|--------|
| funct7                    | rs2      |        | rs1 | func      | t3  | re          | l       | opcode | R-type |
|                           |          |        |     |           |     |             |         |        |        |
| imm[1                     | 1:0]     |        | rs1 | func      | et3 | ro          | l       | opcode | I-type |
|                           |          |        |     |           |     |             |         |        |        |
| imm[11:5]                 | rs2      |        | rs1 | func      | t3  | $_{ m imm}$ | 4:0]    | opcode | S-type |
|                           |          |        |     |           |     |             |         |        | _      |
| $[imm[12] \mid imm[10:5]$ | rs2      |        | rs1 | func      | et3 | imm[4:1]    | imm[11] | opcode | B-type |
|                           |          |        |     |           |     |             |         |        |        |
|                           | imm[31:1 | 12]    |     |           |     | ro          | l       | opcode | U-type |
|                           |          |        |     |           |     |             |         |        | _      |
| [imm[20]] $imm[10]$       | 0:1] ir  | nm[11] | imr | n[19:12]  |     | ro          | l       | opcode | J-type |

FIGURE 1: RISC-V Instruction Formats

### 2.Instructions in RV32IM

### 2.1. Integer Computational Instructions

#### 2.1.1. Register - Immediate Instructions

| Instruction | Instruction<br>Name                          | Example        | Description                                                                                                             | Instruction<br>Type |
|-------------|----------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------|---------------------|
| ADDI        | Add<br>immediate<br>Unsigned                 | ADDI x1, x2, 3 | Reg[x1] <- Reg[x2] + 3                                                                                                  | I - Type            |
| SLTI        | Set less than<br>Immediate                   | SLTI x1, x2, 3 | if (Regs[x2] > 3): Regs[x1] <- 1 else: Regs[x1] <- 0 (Signed Comparison)                                                | I - Type            |
| SLTIU       | SLTIU Set less than<br>Immediate<br>Unsigned |                | if (Regs[x2] > 3):  Regs[x1] <- 1  else: Regs[x1] <- 0 (Unsigned Comparison)                                            | I - Type            |
| ANDI        | Logical AND<br>immediate                     | ANDI x1, x2, 3 | Reg[x1] <- Reg[x2] & 3                                                                                                  | I - Type            |
| ORI         | ORI Logical OR immediate                     |                | Reg[x1] <- Reg[x2]   3                                                                                                  | I - Type            |
| XORI        | Logical XOR<br>immediate                     | XORI x1, x2, 3 | Reg[x1] <- Reg[x2] ^ 3                                                                                                  | I - Type            |
| SLLI        | Logical Left<br>shift<br>Immediate           | SLLI x1, x2, 3 | Reg[x1] <- Reg[x2] << 3                                                                                                 | I - Type            |
| SRLI        | Logical right<br>Shift<br>Immediate          | SRLI x1, x2, 3 | Reg[x1] <- Reg[x2] >> 3<br>(zeros are shifted into the<br>upper bits)                                                   | I - Type            |
| SRAI        | Arithmetic<br>Right Shift                    | SRAI x1, x2, 3 | Reg[x1] <- Reg[x2] >> 3 (Original Sign bit is copied into the vacated upper bits)                                       | I - Type            |
| LUI         | Load Upper<br>Immediate                      | LUI x1, 3      | Reg[x1] <- [3] <sub>20 bits</sub> [0] <sub>12 bits</sub> immediate value in the top 20 bits & lowest 12 bits with zeros | U - Type            |
| AUIPC       | Add upper<br>immediate to<br>PC              | ALUPC x1, 3    | Reg[x1]<-PC+[[3] <sub>20 bits</sub> [0] <sub>12</sub> ]                                                                 | U - Type            |

TABLE 1: Register - Immediate Instructions

|   | 31                          | 20 19                | 15 14 | 12       | 11 7                  | 7 6    | 0 |
|---|-----------------------------|----------------------|-------|----------|-----------------------|--------|---|
|   | imm[11:0]                   | rs1                  | fı    | ınct3    | rd                    | opcode |   |
| _ | 12                          | 5                    |       | 3        | 5                     | 7      |   |
|   | $\hbox{I-immediate} [11:0]$ | $\operatorname{src}$ | ADDI  | /SLTI[U] | $\operatorname{dest}$ | OP-IMM |   |
|   | $\hbox{I-immediate} [11:0]$ | $\operatorname{src}$ | ANDI  | /ORI/XO  | RI dest               | OP-IMM |   |

| <br>31    | $25\ 24$           | 20       | 19                   | $15 \ 14$ |                       | 12 | 11                    | 7 6 |                         | 0 |
|-----------|--------------------|----------|----------------------|-----------|-----------------------|----|-----------------------|-----|-------------------------|---|
| imm[11:5] | im                 | 1m[4:0]  | rs1                  |           | funct3                |    | $\operatorname{rd}$   |     | $\operatorname{opcode}$ |   |
| 7         |                    | 5        | 5                    |           | 3                     |    | 5                     |     | 7                       |   |
| 0000000   | ${ m sh} \epsilon$ | amt[4:0] | $\operatorname{src}$ |           | SLLI                  |    | $\operatorname{dest}$ |     | OP-IMM                  |   |
| 0000000   | ${ m sh} \epsilon$ | amt[4:0] | $\operatorname{src}$ |           | $\operatorname{SRLI}$ |    | $\operatorname{dest}$ |     | OP-IMM                  |   |
| 0100000   | ${ m sh} \epsilon$ | amt[4:0] | $\operatorname{src}$ |           | $\operatorname{SRAI}$ |    | $\operatorname{dest}$ |     | OP-IMM                  |   |

FIGURE 2: Register - Immediate Instruction encoding formats

#### 2.1.2. Register - Register Instructions

| Instruction                | Instruction<br>Name                                                                                                       | Example        | Description                                                                             | Instruction<br>Type |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------|----------------|-----------------------------------------------------------------------------------------|---------------------|
| ADD                        | Addition                                                                                                                  | ADD x1, x2, x3 | Reg[x1] <- Reg[x2] + Reg[x3]                                                            | R - Type            |
| SLT                        | Set less<br>than                                                                                                          | SLT x1, x2, x3 | if (Regs[x2]>Regs[x3]): Regs[x1]<-1<br>else: Regs[x1] <- 0<br>(Signed Comparison)       | R - Type            |
| SLTU                       | TU Set less than unsigned SLTU x1, x2, x3 if (Regs[x2] > Regs[x3]): Regs[x1] <- 1 else: Regs[x1] <- 0 (Signed Comparison) |                | R - Type                                                                                |                     |
| AND                        | AND Bitwise logical AND                                                                                                   |                | Reg[x1] <- Reg[x2] & Regs[x3]                                                           | R - Type            |
| OR                         | Bitwise<br>logical OR                                                                                                     | OR x1, x2, x3  | Reg[x1] <- Reg[x2]   Regs[x3]                                                           | R - Type            |
| XOR                        | Bitwise<br>logical XOR                                                                                                    | XOR x1, x2, x3 | Reg[x1] <- Reg[x2] ^ Regs[x3]                                                           | R - Type            |
| SLL                        | Logical Left<br>Shift                                                                                                     | SLL x1, x2, x3 | Reg[x1] <- Reg[x2] << Regs[x3]                                                          | R - Type            |
| SRL Logical<br>Right Shift |                                                                                                                           | SRL x1, x2, x3 | Reg[x1] <- Reg[x2] >> 3 (zeros are shifted into the upper bits)                         | R - Type            |
| SUB                        | Subtraction                                                                                                               | SUB x1, x2, x3 | Reg[x1] <- Reg[x2] - Reg[x3]                                                            | R - Type            |
| SRA                        | Arithmetic<br>Right shift                                                                                                 | SRA x1,x2,x3   | Reg[x1] <- Reg[x2] >> Reg[x3] (Original Sign bit is copied into the vacated upper bits) | R - Type            |

TABLE 2: Register - Register Instructions

| 31     | 25 | 24 2            | 0 19                  | 15 | 14 1:       | 2 11 | 7                     | 6      | 0 |
|--------|----|-----------------|-----------------------|----|-------------|------|-----------------------|--------|---|
| funct7 |    | rs2             | rs1                   |    | funct3      |      | $\operatorname{rd}$   | opcode |   |
| 7      |    | 5               | 5                     |    | 3           |      | 5                     | 7      |   |
| 000000 | 0  | src2            | $\operatorname{src}1$ | A  | ADD/SLT/SLT | ΤU   | $\operatorname{dest}$ | OP     |   |
| 000000 | 0  | src2            | $\operatorname{src}1$ | 1  | AND/OR/XOF  | ?    | $\operatorname{dest}$ | OP     |   |
| 000000 | 0  | $\mathrm{src}2$ | $\operatorname{src}1$ |    | SLL/SRL     |      | $\operatorname{dest}$ | OP     |   |
| 010000 | 0  | $\mathrm{src}2$ | $\operatorname{src}1$ |    | SUB/SRA     |      | $\operatorname{dest}$ | OP     |   |

FIGURE 3: Register - Register Instruction Encoding Format

### 2.2. Control Transfer Instructions

| Instruction | Instruction<br>Name                               | Example               | Description                                                                 | Instruction<br>Type |
|-------------|---------------------------------------------------|-----------------------|-----------------------------------------------------------------------------|---------------------|
| JAL         | Jump and<br>Link                                  | JAL x1, offset        | Regs[x1] <- PC+4;<br>PC <- PC + ( offset << 1)                              | J - Type            |
| JALR        | Jump and<br>link register                         | JALR x1, x2,offset    | Regs[x1] <- PC+4;<br>PC<-Regs[x2]+(offset<<1)                               | I - Type            |
| BEQ         | Branch<br>Equal                                   | BEQ x1, x2,offset     | if(Regs[x1]== Regs[x2]):<br>PC<-PC+(offset<< 1)                             | B - Type            |
| BNE         | Branch Not<br>Equal                               | BNE x1, x2,offset     | if(Regs[x1] != Regs[x2]):<br>PC <- PC+(offset<< 1)                          | В - Туре            |
| BLT         | Branch Less<br>Than                               | BLT x1, x2,offset     | if(Regs[x1] < Regs[x2]):<br>PC <- PC+(offset<< 1)                           | B - Type            |
| BLTU        | Branch Less<br>Than<br>unsigned                   | BLTU x1, x2,offset    | if(Regs[x1] < Regs[x2]):<br>PC <- PC+(offset<< 1)<br>(Unsigned comparison)  | B - Type            |
| BGE         | Branch<br>Greater<br>than or<br>equal             | BGE x1, x2,offset     | if(Regs[x1] > Regs[x2]):<br>PC <- PC+ (offset<< 1)                          | B - Type            |
| BGEU        | Branch<br>Greater<br>than or<br>Equal<br>Unsigned | BGEU x1,<br>x2,offset | if(Regs[x1] > Regs[x2]):<br>PC <- PC+ (offset<< 1)<br>(Unsigned comparison) | B - Type            |

TABLE 3 : Control Transfer Instructions



FIGURE 4: Control Transfer Instruction Encoding Formats

#### 2.3. Load and Store Instructions

| Instruction | Instruction<br>Name                       | Example        | Description                                                               | Instructio<br>n Type |
|-------------|-------------------------------------------|----------------|---------------------------------------------------------------------------|----------------------|
| LW          | Load<br>Word(32bit)                       | Lw x1, 60(x2)  | Regs[x1]<- Mem[60+Regs[x2]] <sub>32 bit</sub>                             | I - Type             |
| LH          | Load Half LH x1, 60(x2) word (16 bit)     |                | Regs[x1]<- [Mem[60+Regs[x2]]] <sub>16 bit</sub><br>Sign extend to 32 bits | I - Type             |
| LHU         | LHU Load half LHU x1,<br>word<br>Unsigned |                | Regs[x1]<- [Mem[60+Regs[x2]]] <sub>16 bit</sub><br>Zero extend to 32 bits | I - Type             |
| LB          | Load Byte<br>(8 bit)                      | LB x1, 60(x2)  | Regs[x1]<- [Mem[60+Regs[x2]]] <sub>8 bit</sub><br>Sign extend to 32 bits  | I - Type             |
| LBU         | Load Byte<br>Unsigned                     | LBU x1, 60(x2) | Regs[x1]<- [Mem[60+Regs[x2]]] <sub>8 bit</sub><br>Zero extend to 32 bits  | I - Type             |
| SW          | Store Word                                | SW x1, 60(x2)  | [Mem[60+Regs[x2]]] <- Reg[x1] <sub>32 bit</sub>                           | S - Type             |
| SH          | Store Half<br>word                        | SH x1, 60(x2)  | [Mem[60+Regs[x2]]] <- Reg[x1] <sub>16 bit</sub>                           | S - Type             |
| SB          | Store Byte                                | SB x1, 60(x2)  | [Mem[60+Regs[x2]]] <- Reg[x1] <sub>8 bit</sub>                            | S - Type             |

**TABLE 4: Load and Store Instructions** 



FIGURE 5: Load and Store Instruction Encoding Formats

#### 2.4. Multiplication / Division Instructions

| Instruction | Instruction<br>Name                           | Example            | Description                                                               | Instruction<br>Type |
|-------------|-----------------------------------------------|--------------------|---------------------------------------------------------------------------|---------------------|
| MUL         | Multiplicati<br>on                            | MUL x1,x2,x3       | Reg[x1]<-[Reg[x2]*Reg[x3]] <sub>lower 32bit</sub>                         | R - Type            |
| MULH        | Multiplicati<br>on High                       | MULH<br>x1,x2,x3   | Reg[x1]<-[Reg[x2]*Reg[x3]] <sub>upper32bit</sub><br>Signed x Signed       | R - Type            |
| MULHU       | Multiplicati<br>on High<br>Unsigned           | MULHU<br>x1,x2,x3  | Reg[x1]<-[Reg[x2]*Reg[x3]] <sub>upper32bit</sub> (Unsigned x Unsigned)    | R - Type            |
| MULHSU      | Multiplicati<br>on High<br>Signed<br>UnSigned | MULHSU<br>x1,x2,x3 | Reg[x1]<-[Reg[x2]*Reg[x3]] <sub>upper32bit</sub> (Signed x Unsigned)      | R - Type            |
| DIV         | Division                                      | DIV x1,x2,x3       | Reg[x1]<-[Reg[x2] / Reg[x3]]<br>(Signed Division) Round towards<br>Zero   | R - Type            |
| DIVU        | Division<br>Unsigned                          | DIVU x1,x2,x3      | Reg[x1]<-[Reg[x2] / Reg[x3]]<br>(Unsigned Division) Round<br>towards Zero | R - Type            |
| REM         | Remainder                                     | REM x1,x2,x3       | Reg[x1]<-[Reg[x2] % Reg[x3]] Sign of the result = Sign of the dividend    | R - Type            |
| REMU        | Remainder<br>Unsigned                         | REMUx1,x2,x3       | Reg[x1]<-[Reg[x2] % Reg[x3]]<br>(Unsigned Division)                       | R - Type            |

TABLE 5: Multiplication & Division Instructions

| 31     | 25 24   | 20 19        | 15 14         | 12 11          | 7 6    | 0 |
|--------|---------|--------------|---------------|----------------|--------|---|
| funct7 | rs      | 2 rs         | 1 fund        | et3 rd         | opcode |   |
| 7      | 5       | 5            | 3             | 5              | 7      |   |
| MULDI  | V multi | plier multip | licand MUL/MU | ULH[[S]U] dest | OP     |   |

| 31   | 25 24    | 20 19      | 15 14        | 12 11       | 7 6    | 0 |
|------|----------|------------|--------------|-------------|--------|---|
| func | t7 rs    | 2 rs1      | func         | t3 rd       | opcode |   |
| 7    | 5        | 5          | 3            | 5           | 7      |   |
| MUL  | DIV divi | sor divide | end DIV[U]/R | REM[U] dest | OP     |   |

FIGURE 6: Multiplication & Division Instruction Encoding Formats

#### 2.5. Memory Ordering Instruction

The FENCE instruction is used to order device I/O and memory accesses as viewed by other RISC-V harts and external devices or coprocessors. FENCE instruction that provides explicit synchronization between writes to instruction memory and instruction fetches on the same hart.



FIGURE 7: Memory Ordering Instruction Encoding Format

#### 2.6. Environment Call and Breakpoints

SYSTEM instructions are used to access system functionality that might require privileged access and are encoded using the I-type instruction format

The ECALL instruction is used to make a service request to the execution environment.

The EBREAK instruction is used to return control to a debugging environment.

| 31      | 20 19 | 15 14 12 1 | 1                   | 7 6 0  |
|---------|-------|------------|---------------------|--------|
| funct12 | rs1   | funct3     | $\operatorname{rd}$ | opcode |
| 12      | 5     | 3          | -5                  | 7      |
| ECALL   | 0     | PRIV       | 0                   | SYSTEM |
| EBREAK  | 0     | PRIV       | 0                   | SYSTEM |

FIGURE 8: System Instructions Encoding Format

## 3. Opcodes

The OPCODES used in the RISC - V manual were used as the OPCODES to implement the RV32IM.

RV32I Base Instruction Set

|                                                              | imm[31:12] | Dasc Insti | detion 5 | rd                  | 0110111 | LUI   |
|--------------------------------------------------------------|------------|------------|----------|---------------------|---------|-------|
|                                                              | rd         | 0010111    | AUIPC    |                     |         |       |
| $\frac{\mathrm{imm}[31:12]}{\mathrm{imm}[20 10:1 11 19:12]}$ |            |            |          | rd                  | 1101111 | JAL   |
| imm[11:0                                                     | rs1        | 000        | rd       | 1100111             | JALR    |       |
| imm[12 10:5]                                                 |            |            | 000      | imm[4:1 11]         | 1100011 | BEQ   |
| imm[12 10:5]                                                 | rs2        | rs1<br>rs1 | 001      | imm[4:1 11]         | 1100011 | BNE   |
| imm[12 10:5]                                                 | rs2        | rs1        | 100      | imm[4:1 11]         | 1100011 | BLT   |
| imm[12 10:5]                                                 | rs2        | rs1        | 101      | imm[4:1 11]         | 1100011 | BGE   |
| imm[12 10:5]                                                 | rs2        | rs1        | 110      | imm[4:1 11]         | 1100011 | BLTU  |
| imm[12 10:5]                                                 | rs2        | rs1        | 111      | imm[4:1 11]         | 1100011 | BGEU  |
| imm[11:0                                                     |            | rs1        | 000      | rd                  | 0000011 | LB    |
| imm 11:0                                                     | J          | rs1        | 001      | rd                  | 0000011 | LH    |
| imm[11:0                                                     | 0]         | rs1        | 010      | rd                  | 0000011 | LW    |
| imm[11:0                                                     | 0]         | rs1        | 100      | rd                  | 0000011 | LBU   |
| imm[11:0                                                     | 0]         | rs1        | 101      | $^{\mathrm{rd}}$    | 0000011 | LHU   |
| imm[11:5]                                                    | rs2        | rs1        | 000      | imm[4:0]            | 0100011 | SB    |
| imm[11:5]                                                    | rs2        | rs1        | 001      | imm[4:0]            | 0100011 | SH    |
| imm[11:5]                                                    | rs2        | rs1        | 010      | imm[4:0]            | 0100011 | SW    |
| imm[11:0                                                     | 0]         | rs1        | 000      | rd                  | 0010011 | ADDI  |
| imm[11:0]                                                    |            | rs1        | 010      | $^{\mathrm{rd}}$    | 0010011 | SLTI  |
| imm[11:0                                                     | imm[11:0]  |            | 011      | rd                  | 0010011 | SLTIU |
| imm[11:0]                                                    |            | rs1        | 100      | rd                  | 0010011 | XORI  |
| imm[11:0]                                                    |            | rs1        | 110      | $^{\mathrm{rd}}$    | 0010011 | ORI   |
| imm[11:0                                                     | 0]         | rs1        | 111      | $^{\mathrm{rd}}$    | 0010011 | ANDI  |
| 0000000                                                      | shamt      | rs1        | 001      | rd                  | 0010011 | SLLI  |
| 0000000                                                      | shamt      | rs1        | 101      | rd                  | 0010011 | SRLI  |
| 0100000                                                      | shamt      | rs1        | 101      | rd                  | 0010011 | SRAI  |
| 0000000                                                      | rs2        | rs1        | 000      | rd                  | 0110011 | ADD   |
| 0100000                                                      | rs2        | rs1        | 000      | rd                  | 0110011 | SUB   |
| 0000000                                                      | rs2        | rs1        | 001      | rd                  | 0110011 | SLL   |
| 0000000                                                      | rs2        | rs1        | 010      | rd                  | 0110011 | SLT   |
| 0000000                                                      | rs2        | rs1        | 011      | rd                  | 0110011 | SLTU  |
| 0000000                                                      | rs2        | rs1        | 100      | rd                  | 0110011 | XOR   |
| 0000000 rs2                                                  |            | rs1        | 101      | $\operatorname{rd}$ | 0110011 | SRL   |
| 0100000 rs2                                                  |            | rs1        | 101      | rd                  | 0110011 | SRA   |
| 0000000 rs2                                                  |            | rs1        | 110      | rd                  | 0110011 | OR    |
| 0000000                                                      | rs2        | rs1        | 111      | $^{\mathrm{rd}}$    | 0110011 | AND   |
| fm pre                                                       |            | rs1        | 000      | $^{\mathrm{rd}}$    | 0001111 | FENCE |
| 000000000                                                    |            | 00000      | 000      | 00000               | 1110011 | ECALL |
| 000000000                                                    | 001        | 00000      | 000      | 00000               | 1110011 | BREAK |

#### RV32M Standard Extension

| 0000001 | rs2 | rs1 | 000 | $^{\mathrm{rd}}$ | 0110011 | MUL    |
|---------|-----|-----|-----|------------------|---------|--------|
| 0000001 | rs2 | rs1 | 001 | $^{\mathrm{rd}}$ | 0110011 | MULH   |
| 0000001 | rs2 | rs1 | 010 | rd               | 0110011 | MULHSU |
| 0000001 | rs2 | rs1 | 011 | rd               | 0110011 | MULHU  |
| 0000001 | rs2 | rs1 | 100 | rd               | 0110011 | DIV    |
| 0000001 | rs2 | rs1 | 101 | rd               | 0110011 | DIVU   |
| 0000001 | rs2 | rs1 | 110 | rd               | 0110011 | REM    |
| 0000001 | rs2 | rs1 | 111 | rd               | 0110011 | REMU   |

FIGURE 9: RV32IM OPCODES and Instruction Set Formats

## 4. Pipeline Datapath



FIGURE 10: Pipeline Diagram with Datapaths and Controls

#### 5. Hardware Units

- Instruction Memory
- Register File (32 x 32 bit registers)
- ALU (Multiplication and shifting hardware included)
- Data Memory
- Control Unit
- Branch logic (For comparing and generating the control signal related to branch and jump instruction)
- Immediate selecting hardware (Hardware to select the correct immediate format and for sign extending)

### 6. Control Signals

- ALUOP ALU operating selection
- REG WRITE EN Enable the writing to the Register File
- PC\_SEL Select the source to the PC register
- IMM\_SEL Select the correct format of the immediate
- OP1SEL Select the ALU operand 1 source
- OP2SEL Select the ALU operand 2 source
- MEM\_WRITE Enable writing to the data memory
- MEM\_READ Enable reading from the data memory
- WB\_SEL Select the write back value source
- BRANCH\_JUMP Select the branch comparing type and the jump

| INSTRUCTIO |          |         |        |        |         | MEM_WR | MEM_RE | REG_WR |        | BRANCH_ |
|------------|----------|---------|--------|--------|---------|--------|--------|--------|--------|---------|
| N          | PC_SEL   | IMM_SEL | OP1SEL | OP2SEL | ALUOP   | ITE    | AD     | ITE_EN | WB_SEL | JUMP    |
| LUI        | PC + 4   | U       | *      | IMM    | FORWARD | 0      | 0      | 1      | ALU    | 000     |
| AUIPC      | PC + 4   | U       | PC     | IMM    | ADD     | 0      | 0      | 1      | ALU    | 000     |
| JAL        | ALU      | J       | PC     | IMM    | ADD     | 0      | 0      | 1      | PC + 4 | 111     |
| JALR       | ALU      | I       | DATA1  | IMM    | ADD     | 0      | 0      | 1      | PC + 4 | 111     |
|            | PC + 4 / |         |        |        |         |        |        |        |        |         |
| BEQ        | ALU      | В       | PC     | IMM    | ADD     | 0      | 0      | 0      | *      | 001     |
|            | PC + 4 / |         |        |        |         |        |        |        |        |         |
| BNE        | ALU      | В       | PC     | IMM    | ADD     | 0      | 0      | 0      | *      | 010     |
|            | PC + 4 / |         |        |        |         |        |        |        |        |         |
| BLT        | ALU      | В       | PC     | IMM    | ADD     | 0      | 0      | 0      | *      | 011     |
|            | PC + 4 / |         |        |        |         |        |        |        |        |         |
| BGE        | ALU      | В       | PC     | IMM    | ADD     | 0      | 0      | 0      | *      | 100     |
|            | PC + 4 / |         |        |        |         |        | _      |        |        |         |
| BLTU       | ALU      | В       | PC     | IMM    | ADD     | 0      | 0      | 0      | *      | 101     |
| DCELL      | PC + 4/  |         | DC     | 18484  | ADD     |        |        |        | *      | 110     |
| BGEU       | ALU      | B .     | PC     | IMM    | ADD     | 0      | 0      | 0      |        | 110     |
| LB         | PC + 4   | I       | DATA1  | IMM    | ADD     | 0      | 1      | 1      | MEM    | 000     |
| LH         | PC + 4   | I       | DATA2  | IMM    | ADD     | 0      | 1      | 1      | MEM    | 000     |
| LW         | PC + 4   | I       | DATA3  | IMM    | ADD     | 0      | 1      | 1      | MEM    | 000     |
| LBU        | PC + 4   | I       | DATA4  | IMM    | ADD     | 0      | 1      | 1      | MEM    | 000     |
| LHU        | PC + 4   | I       | DATA5  | IMM    | ADD     | 0      | 1      | 1      | MEM    | 000     |
| SB         | PC + 4   | S       | DATA6  | IMM    | ADD     | 1      | 0      | 0      | *      | 000     |
| SH         | PC + 4   | S       | DATA7  | IMM    | ADD     | 1      | 0      | 0      | *      | 000     |
| SW         | PC + 4   | S       | DATA8  | IMM    | ADD     | 1      | 0      | 0      | *      | 000     |
| ADDI       | PC + 4   | I       | DATA1  | IMM    | ADD     | 0      | 0      | 1      | ALU    | 000     |
| SLTI       | PC + 4   | I       | DATA1  | IMM    | SLT     | 0      | 0      | 1      | ALU    | 000     |
| SLTIU      | PC + 4   | ΙU      | DATA1  | IMM    | SLTU    | 0      | 0      | 1      | ALU    | 000     |
| XORI       | PC + 4   | I       | DATA1  | IMM    | XOR     | 0      | 0      | 1      | ALU    | 000     |
| ORI        | PC + 4   | I       | DATA1  | IMM    | OR      | 0      | 0      | 1      | ALU    | 000     |
| ANDI       | PC + 4   | I       | DATA1  | IMM    | AND     | 0      | 0      | 1      | ALU    | 000     |
| SLLI       | PC + 4   | SFT     | DATA1  | IMM    | SLL     | 0      | 0      | 1      | ALU    | 000     |
| SRLI       | PC + 4   | SFT     | DATA1  | IMM    | SRL     | 0      | 0      | 1      | ALU    | 000     |
| SRAI       | PC + 4   | SFT     | DATA1  | IMM    | SRA     | 0      | 0      | 5      | ALU    | 000     |

| ADD    | PC + 4 | * | DATA1 | DATA2 | ADD    | 0 | 0 | 1 | ALU | 000 |
|--------|--------|---|-------|-------|--------|---|---|---|-----|-----|
| SUB    | PC + 4 | * | DATA1 | DATA2 | SUB    | 0 | 0 | 1 | ALU | 000 |
| SLL    | PC + 4 | * | DATA1 | DATA2 | SLL    | 0 | 0 | 1 | ALU | 000 |
| SLT    | PC + 4 | * | DATA1 | DATA2 | SLT    | 0 | 0 | 1 | ALU | 000 |
| SLTU   | PC + 4 | * | DATA1 | DATA2 | SLTU   | 0 | 0 | 1 | ALU | 000 |
| XOR    | PC + 4 | * | DATA1 | DATA2 | XOR    | 0 | 0 | 1 | ALU | 000 |
| SRL    | PC + 4 | * | DATA1 | DATA2 | SRL    | 0 | 0 | 1 | ALU | 000 |
| SRA    | PC + 4 | * | DATA1 | DATA2 | SRA    | 0 | 0 | 1 | ALU | 000 |
| OR     | PC + 4 | * | DATA1 | DATA2 | OR     | 0 | 0 | 1 | ALU | 000 |
| AND    | PC + 4 | * | DATA1 | DATA2 | AND    | 0 | 0 | 1 | ALU | 000 |
| MUL    | PC + 4 | * | DATA1 | DATA2 | MUL    | 0 | 0 | 1 | ALU | 000 |
| MULH   | PC + 4 | * | DATA1 | DATA2 | MULH   | 0 | 0 | 1 | ALU | 000 |
| MULHSU | PC + 4 | * | DATA1 | DATA2 | MULHSU | 0 | 0 | 1 | ALU | 000 |
| MULHU  | PC + 4 | * | DATA1 | DATA2 | MULHU  | 0 | 0 | 1 | ALU | 000 |
| DIV    | PC + 4 | * | DATA1 | DATA2 | DIV    | 0 | 0 | 1 | ALU | 000 |
| DIVU   | PC + 4 | * | DATA1 | DATA2 | DIVU   | 0 | 0 | 1 | ALU | 000 |
| REM    | PC + 4 | * | DATA1 | DATA2 | REM    | 0 | 0 | 1 | ALU | 000 |
| REMU   | PC + 4 | * | DATA1 | DATA2 | REMU   | 0 | 0 | 1 | ALU | 000 |

TABLE 6: Instructions and Related Control Signals